<!-- 父级页面:除登录页以外所有页面的共有头部和左侧侧边栏在这里写 -->
<template>
  <div style="display: flex">
    <div style="width: 208px;">
      <el-menu
          background-color="#3c82f5"
          style="width: 100%;height: 100vh;"
          text-color="#fff"
          active-text-color="#ff0"
          unique-opened
          router
          :collapse-transition="false"
      >
        <el-row style="padding:5px 5px;margin-bottom: 10px;">
            <span style="color: #fff;font-weight: bold;position: relative;top:8px;left:2px;">CRM管理系统</span>
        </el-row>
        <el-sub-menu index="1">
          <template #title>
            <el-icon style="font-size: 21px;"><User/></el-icon>
            <span>客户管理</span>
          </template>
          <el-menu-item index="">客户管理</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="2">
          <template #title>
            <el-icon style="font-size: 21px;"><Van/></el-icon>
            <span>订单管理</span>
          </template>
          <el-menu-item index="">订单管理</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="3">
          <template #title>
            <el-icon style="font-size: 21px;"><Location/></el-icon>
            <span>工程管理</span>
          </template>
          <el-menu-item index="">工程管理</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="4">
          <template #title>
            <el-icon style="font-size: 21px;"><Place/></el-icon>
            <span>系统管理</span>
          </template>
          <el-menu-item index="">角色权限管理</el-menu-item>
          <el-menu-item index="/systemNotice">系统公告</el-menu-item>
          <el-menu-item index="/operateLog">用户操作日志</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="5">
          <template #title>
            <el-icon style="font-size: 21px;"><Reading /></el-icon>
            <span>数据中心</span>
          </template>
          <el-menu-item index="">数据报表</el-menu-item>
          <el-menu-item index="">业务指标</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="6">
          <template #title>
            <el-icon style="font-size: 21px;"><Reading /></el-icon>
            <span>财务管理</span>
          </template>
          <el-menu-item index="">定金管理</el-menu-item>
          <el-menu-item index="">工程订单管理</el-menu-item>
          <el-menu-item index="">退单管理</el-menu-item>
        </el-sub-menu>
        <el-sub-menu index="7">
          <template #title>
            <el-icon style="font-size: 21px;"><Reading /></el-icon>
            <span>人事管理</span>
          </template>
          <el-menu-item index="">员工管理</el-menu-item>
          <el-menu-item index="">组织架构管理</el-menu-item>
        </el-sub-menu>
      </el-menu>
    </div>
    <div style="width: calc((100% - 208px));" >
      <!--  右侧顶部条    -->
      <el-header style="padding-top: 20px;background-color:#fff ;height: 10vh;">
        <!--    退出登录    -->
        <el-row>
          <el-col :span="18">

          </el-col>
          <el-col :span="2">
            <span style="position: relative;left: 88px;margin: 0;">
              <el-icon size="30px"><Bell /></el-icon>
            </span>
          </el-col>
          <el-col :span="2" >
            <span style="position: relative;left: 88px;">
              <el-icon size="30px" @click="handleIconClick"><ChatDotSquare /></el-icon>
            </span>

          </el-col>
          <el-col :span="2" style="position: relative;">
            <el-dropdown trigger="click" style="position: absolute;right: 20px;">
              <span style="font-size: 19px;font-weight: bold;">
                {{user.username}}
                <el-icon><arrow-down /></el-icon>
              </span>
              <template #dropdown>
                <el-dropdown-menu>
                  <el-dropdown-item @click="">退出登录</el-dropdown-item>
                </el-dropdown-menu>
              </template>
            </el-dropdown>
          </el-col>
        </el-row>
        <!-- 面包屑导航 -->
        <el-breadcrumb separator="/" style="position: relative;top:20px;">
          <el-breadcrumb-item>个人中心</el-breadcrumb-item>
          <el-breadcrumb-item v-for="item in breadcrumb">{{item}}</el-breadcrumb-item>
          <!--          <el-breadcrumb-item>用户管理</el-breadcrumb-item>-->
          <!--          <el-breadcrumb-item>用户列表</el-breadcrumb-item>-->
        </el-breadcrumb>
      </el-header>
      <!--  右侧的主体内容:也是除顶部条与面包屑之外的可变区域,可变内容在各个子页面中写    -->
      <el-main style="height: 90vh;padding: 0;overflow-y: auto;">
        <router-view/>
      </el-main>

    </div>
  </div>
</template>

<script setup>
import {onMounted, ref} from "vue";
import {useRoute, useRouter} from "vue-router";
//获取当前登录的用户数据
const user = ref({
  username:'tom'
});
//定义退出登录的方法
const logout = ()=>{

}
//定义一个数组对象用来保存面包屑导航的值
const breadcrumb = ref([]);
//定义一个对象用来维护路径与面包屑数组值的对应关系
let map = {
  '/user':['客户管理','客户管理'],
  '/orders':['订单管理','订单管理'],
  '/geofence':['工程管理','工程管理'],
  '/geofenceMap':['系统管理','角色权限管理'],
  '/systemNotice':['系统管理','系统公告'],
  '/operateLog':['系统管理','用户操作日志'],
  '/audit':['数据中心','数据报表'],
  '/distribute':['数据中心','业务指标'],
  '/dict':['财务管理','定金管理'],
  '/dict1':['财务管理','工程订单管理'],
  '/dict2':['财务管理','退单管理'],
  '/dict3':['人事管理','员工管理'],
  '/dict4':['人事管理','组织架构管理'],
  '/notice':['系统公告列表'],
  '/noticeDetails':['系统公告列表','系统公告详情']
}
//useRoute()是Vue路由器提供的一个获取当前路由器对象的方法
const route = useRoute();
//定义一个更新面包屑的方法
const updateBreadcrumb = (route)=>{
  //获取当前路由的path值
  const path = route.path;
  //从map对象中取出指定path对应的面包屑数组值,赋值给被遍历的面包屑数组
  breadcrumb.value = map[path] || ['客户管理','客户管理'];
}
//一进到页面立即执行的方法onMounted()
onMounted(()=>{
  updateBreadcrumb(route);
  router.push('/notice');
})
//监听路由,如果路由发生了改变,就执行updateBreadcrumb()方法
const router = useRouter();
router.beforeEach((to, from, next)=>{
  //立即更新面包屑的值,更新为新路径对应的面包屑的值
  updateBreadcrumb(to);
  //再进行路由跳转
  next();
})
//定义跳转公告栏列表页面的方法
const handleIconClick = ()=> {
  router.push('/notice');
}
</script>